草庐IT

c++ - std::auto_ptr、delete[] 和泄漏

全部标签

c++ - 我是否正确实现了时钟漂移?

我在任何地方都找不到任何适用于Windows的时钟漂移RNG代码,所以我尝试自己实现它。我还没有通过ent或DIEHARD运行这些数字,我只是想知道这是否是正确的...voidQueryRDTSC(__int64*tick){__asm{xoreax,eaxcpuidrdtscmovedi,dwordptrtickmovdwordptr[edi],eaxmovdwordptr[edi+4],edx}}__int64clockDriftRNG(){__int64CPU_start,CPU_end,OS_start,OS_end;//getCPUticks--usesRDTSContheP

创建一个简单的计时器应用程序

海湾合作委员会4.4.3VC++2008我想制作一个计时器应用程序,该应用程序可以在Windows和Linux上移植。但是,开始就足够了。我的想法是启动一个计时器并将其设置为指定的秒数。当时间到期时调用回调函数。这是最好的方法吗?非常感谢, 最佳答案 有很多方法可以做一个定时器。这并不难,但你需要想清楚你想要什么。如果你想调用回调,你通常使用一个线程,在调用你的回调之前休眠直到你的延迟结束。如果不想使用线程,可以定期调用计算时间增量的检查器函数。您的api将是一个带有延迟和函数指针以及回调参数的函数。它将启动一个线程,该线程将在延迟

c - c中的文件写入问题

我在我的c应用程序中写日志文件,写文件的方法是fopen_s(&fMainFile,"c:\\LOG\\Filter.txt","a");fprintf(fMainFile,"SomeText");fclose(fMainFile);我打开handle,写完后我关闭了它,但是写了一段时间后我的应用程序崩溃了,谁能解决这个问题,一次又一次地打开和关闭handle有多危险,或者提出任何其他建议处理文件的方法。 最佳答案 fMainFile是如何定义的?我怀疑你应该:fopen_s(&fMainFile,"c:\\LOG\\Filter.

c++ - 激活上下文导致动态加载的 DLL 上的文件句柄泄漏

我有一个动态加载和卸载的DLL,它需要COMCTL32.dll>=v6.0和MSVCR>=v9.0。为确保加载正确的版本,我在VisualStudio项目设置中启用list文件生成,并将此条目添加到另一个list文件:type="win32"name="Microsoft.Windows.Common-Controls"version="6.0.0.0"processorArchitecture="*"publicKeyToken="6595b64144ccf1df"language="*"/>在一个测试程序中我调用了LoadLibrary()其次是FreeLibrary()该DLL,

c++ - 多线程不利用多核?

我的电脑是双核core2Duo。我已经在应用程序的缓慢区域实现了多线程,但我仍然注意到CPU使用率从未超过50%,并且在多次迭代后仍然滞后。这是正常的吗?我希望它能让我的cpu达到100%,因为我将它分成4个线程。为什么它仍然可以限制在50%?谢谢参见WhatamIdoingwrong?(multithreading)对于我的实现,除了我修复了该代码存在的问题 最佳答案 查看您的代码,您在紧密循环中进行了大量分配——在每次迭代中,您动态分配两个双元素vector,然后将它们推回结果vector(从而复制这些vector);最后一次推

c++ - 从 Windows 网络位置打开文件

我可以从已安装的网络驱动器打开文件,但不能从未安装的网络驱动器打开文件,例如\\mycomp\folder2\hi.bmp有什么解决办法吗? 最佳答案 以下代码片段对我有用:charbuffer[1000];FILE*file;size_tbytesRead;file=fopen("\\\\server\\share\\test.dat","rb");if(file!=NULL){bytesRead=fread(buffer,sizeof(char),sizeof(buffer),file);fclose(file);}另请注意fo

c++ - 谁能解释为什么这两个转换为 unsigned long long 会产生不同的结果?

LARGE_INTEGERlpPerformanceCount,lpFrequency;QueryPerformanceCounter(&lpPerformanceCount);QueryPerformanceFrequency(&lpFrequency);(Count.QuadPart是一个显示CPU计数的longlong)(Freq.QuadPart是一个longlong,表示秒数的频率)尝试实时打印微秒。稳定输出:printf("%llu\n",((longdouble)lpPerformanceCount.QuadPart/lpFrequency.QuadPart)*10000

windows - UMDH 日志(Windows 上的内存泄漏)

我正在使用UMDH工具来分析我的应用程序的内存泄漏。UMDH日志观察到的主要泄漏如下:237856226(241016812-3160586)3704833分配BackTraceE93685198(3704833-19635)BackTraceE9分配ntdll!RtlIpv4StringToAddressExW+00011866ntdll!RtlSubAuthorityCountSid+00000019MSVCR80!malloc+0000007A207093760(207355904-262144)791allocsBackTrace6EB790(791-1)个BackTrace6

c# - 运行 Windows 服务以观察服务运行增长内存(泄漏)

我已经检查了这里的所有帖子,但到目前为止找不到适合我的解决方案。我确实设置了一个小服务,它应该只监视我要监视的其他服务是否运行,如果没有运行,则重新启动它并在应用程序事件日志中放置一条消息。该服务本身运行良好,没什么特别的:),但是当我启动该服务时,它使用大约1.6MB的RAM,并且每10秒它增长60-70k,这足以忍受它。我尝试处理并清除所有资源。尝试使用System.Timers而不是实际的解决方案,但没有任何效果如我所愿,内存仍在增长。调试或发布版本没有区别,我在.Net2上使用它,不知道它对你3、3.5或4是否有影响。有什么提示吗?!usingSystem;usingSyste

c - 防止过多的 LoadLibrary/FreeLibrary

我正在编写一个代理库(称为库A),它只是与系统上可能存在或不存在的另一个DLL(称为库B)的接口(interface)。这个想法是程序将链接到这个库A而不是原始库B;如果系统上没有安装库B,库A将处理错误。所以一个典型的代理函数看起来像这样:intfunction(intarg1,intarg2){HINSTANCEhinstLib;UINTerrormode=SetErrorMode(SEM_FAILCRITICALERRORS);SetErrorMode(errormode|SEM_FAILCRITICALERRORS);hinstLib=LoadLibrary(TEXT(ORIG